



## Systems Reference Library

## IBM 7094 Model II Data Processing System

This announcement bulletin provides information about the IBM 7094-II Data Processing System. It contains a generalized description of the main features of this system, together with a sample instruction sequence and rules for the application of extended sequence overlap operations. A listing of instruction cycle changes, as well as a table of instructions capable of being overlapped, is included.



Increased computational speed, coupled with faster throughput, is provided in the newest addition to IBM data processing systems — the 7094-II. Designed to meet growth requirements for IBM 7090/7094 users, the 7094-II maintains compatibility of programming and data assignments, input/output and random storage configurations, and operations with the 7094.

The salient features of this new system are:

- --- reduced core storage cycle time
- --- extended sequence overlap operations
- --- reduction in cycle times for certain arithmetic operations

Core storage cycle time, together with the basic machine cycle, has been reduced from 2.0 microseconds to 1.4 microseconds.

Extended sequence overlap has been combined with the faster access time, resulting in substantial increases in internal performance.

Average execution times of fixed and floating point multiply and divide instructions have been reduced by one cycle.

The various units of the IBM 7094-II remain the same as for the 7090/7094 with the following exceptions:

The IBM 7302 Model 3 Core Storage unit replaces the IBM 7302 Core Storage unit, the IBM 7111 Instruction Processing unit replaces the IBM 7108 (in 7090) or the IBM 7110 (in 7094), and the IBM 7606 Model 2 Multiplexor is used in place of the IBM 7606 Model 1 Multiplexor.

## OPERATION

Essential to 7094-II operation are two logically independent core storage arrays, each consisting of 16K, 36-bit words with a cycle time of 1.4 microseconds. Two words can be referenced simultaneously, one word in the even array, the other in the odd array. Two words (not necessarily in consecutive locations) can be obtained from storage at the same time, or one word can be obtained while the other word is being stored. Simultaneous store operations are not performed.

The 7094-II can execute a continual flow of overlapped instructions until the sequence of instructions is terminated. This differs from the double instruction overlap in the 7094 where sequences of only two instructions are overlapped. When the 7094 completes such a sequence, it is then possible to achieve overlap in the next two-instruction pair; but overlap between pairs is not possible.

In the extended sequence overlap operation of the 7094-II, long sequences of instructions can be executed with the resultant elimination of all I cycles, except the I cycle of the initial instruction of the sequence. This is accomplished by overlapping the I cycle with the E or L cycle of the preceding instruction.

Two conditions can cause extended sequence overlap to be temporarily suspended. First, certain combinations of the two instructions brought simultaneously from core storage may, by the nature of the instructions, preclude overlap operations; these instructions are listed in Table I. Second, a storage conflict will occur if an address in the operand of the preceding instruction refers to the same core array as the location of the current instruction, that is, if both refer to the even core array or both to the odd core array.

## IBM 7094-II INSTRUCTION CYCLES

The instructions provided in the 7094-II are exactly the same as in the 7094; however, cycle time for instructions has been reduced to 1.4 microseconds. In addition, the number of cycles required by the following instructions has been changed as follows:

|                                   | 7094 II |         |
|-----------------------------------|---------|---------|
| Instruction                       | Cycles  | Average |
| FMP, UFM, MPY, MPR                | 2-4     | 4       |
| FDP, FDH                          | 2-6     | 6       |
| DVP, DVH                          | 2-7     | 7       |
| DFMP, DUFM                        | 2-9     | 9       |
| DFDP, DFDH                        | 2-13    | 13      |
| VDH, VDP                          | 2-7     | _       |
| VLM                               | 2-4     | _       |
| LLS, LRS, LGL, LGR                | 2-6     | _       |
| ALS, ARS, RQL                     | 2-4     | _       |
| SCHX                              | 2-3     | -       |
| ENB                               | 3-4     | -       |
| RCHX, LCHX                        | 4-5     | _       |
| RDS, WRS, BSR, WEF, REW, RUN, SDN | 2-3     | _       |
| RDS, WRS, (Card Machines)         | 3-4     | _       |
| ETT, BTT, TEF, TRC                | 3-4     | _       |
| TCOX, TCNX                        | 2       | _       |

The number of cycles required for a given sequence of instructions is determined by adding up the total number of cycles involved, and subtracting the number of I cycles that can be processed concurrently with the E or L cycle of each preceding instruction. The following rule specifies condition of overlap. The I time for the current instruction need not be counted if (and only if):

1. The current instruction can have its I time overlapped (as shown in Table I), and

| 2. The preceding in | struction | can | have | its | E | (or | L) |  |
|---------------------|-----------|-----|------|-----|---|-----|----|--|
| time overlapped,    | and       |     |      |     |   |     |    |  |

- 3. No storage conflict occurs. This will be the case if (and only if) any of the following occurs:
  - a) The preceding instruction requires at least one L cycle.
  - b) The I time of the preceding instruction was not eliminated due to overlap.
  - c) The location of the current instruction and the data referenced by the preceding instruction are in different core arrays.

The following instruction sequence illustrates the application of this rule.

| Operation    | Cycles Required |
|--------------|-----------------|
| <b>→</b> LDQ | IE              |
| FMP          | (I)ELL          |
| FAD          | (I)EL           |
| STO          | (I)E            |
| TIX          | (I)             |

The cycles enclosed in parentheses may be eliminated. Conditions 1 and 2 hold for all instructions; only condition 3 is involved in the following:

- FMP: Rule 3b is satisfied. I time of the previous instruction, LDQ, was not eliminated.
- FAD: Rule 3a is satisfied. The preceding instruction, FMP, had an L cycle.
- STO: Rule 3a is satisfied. The preceding instruction, FAD, had an L cycle.
- TIX: Neither 3a nor 3b is satisfied. Elimination of the I cycle will occur only if the TIX and the data required by the STO are in different logical storage arrays.

When different storage arrays are used, the total number of cycles required for this sample instruction sequence is eight 1.4 microsecond cycles. The same instruction sequence on the 7094 would be executed as follows:

- The FMP instruction requires an additional L cycle.
- 2. Either one or two I cycles are overlapped, depending upon whether the first instruction is located at an odd or even storage array.

The sample instruction sequence, if processed on a 7094, requires eleven 2-microsecond cycles.

Table I. Listing of Instructions -- Overlap Activity

|            | •            | -                  |                   | X | X  | FMP, UFM, MPY        | I, E, L, L    |
|------------|--------------|--------------------|-------------------|---|----|----------------------|---------------|
|            |              |                    |                   | Λ | Λ. | rivir, Orivi, ivir i | 1, 1, 1, 1    |
| I Cycle    | E or L Cycle |                    |                   | X | X  | MPR                  | I, E, L, L, L |
| Can Be     | Can Be       |                    |                   | X | X  | FDP, FDH             | I, E,4L       |
| Overlapped | Overlapped   | Instructions       | $\subseteq$ ycles | X | X  | DVP                  | I, E, 5L      |
|            |              |                    |                   | X |    | D <b>V</b> H         | I, E, 5L      |
|            |              | IIS, OSI, RIS, LDI | I, E              | X |    | DFMP, DUFM           | I, E, 7L      |
|            |              | SIR, SIL, RIR, RIL | I                 | x |    | DFDP, DFDH           | I, E, 11L     |
|            |              | RIA, PAI, PIA, OAI | I                 | x | x  | VDP                  | I, E, L       |
|            |              | TIO, TIF           | I, L              | x |    | VDH                  | I, E, L       |
| x          |              | PXA. PXD. PCA. PCD | I                 | X | х  | VLM                  | I, E, L-      |

E or L Cycle

Can Be

Х

Х

X

х

Х

Х

Х

Х

Overlapped

Instructions

DLD

DST

STL

XCL

XCA

ZET

TLO

PSF.

MSE

ACI.

ANA

ANS

ERA

ENK

LDQ

HTR

ROL

CAS, LAS

OFT, ONT

IIA, IIL, IIR

Х

X

х

Х

Х

AXT, AXC

TNZ, TZE

TQO

PBT, LBT, DCT

RND, CLM, COM

CVR, CRQ, CAQ

SSM, SSP, CHS

TRA, TTR, ESNT

ALS, ARS, LLS, LRS, LGL,

LFT, LNT, RFT, RNT

FAD, FAM, FSB, FSM

ETM, LTM

LSNM

TCO, TCN

PDC, PDX, PAX, PAC

TIX, TNX, TXL, TXH, TXI

STO, STQ, STZ, SLW, STI

ADD, ADM, SUB, SBM

STP, STO, STT, STA

SXA, SCA, SXD, SCD

LXA, LXD, LAC, LDC

TOP, TPL, TMI, TOV, TNO,

EFTM, LFTM, ESTM, ECTM,

CLA, CLS, CAL

Cycles

Ι

Ι

T

I, E

Ι

Ι

Ι

T

I

I, L

I, L

I, L

I, L

I, E

I, L

I, L

I, E, L

I, E, L

I, L

I, L

I, E

I, L ---

I, L ---

I, L ---

I, E

Ι

I, L, L

I, E, L, L

I, E, L ---

Ι

I, E, L, E

I, L, E ----

Ι

I, E

I, E

I, L

I, E, E

I Cycle Can Be

Overlapped

X

Х

x

х

X

X

Х

х

Х

Х

Х

Х

X

х

Х

Х

Х

Х

 $\mathbf{x}$ 

х

Х

Х

X

Х